//给定一个数字，我们按照如下规则把它翻译为字符串：0 翻译成 “a” ，1 翻译成 “b”，……，11 翻译成 “l”，……，25 翻译成 “z”。一个数字可
//能有多个翻译。请编程实现一个函数，用来计算一个数字有多少种不同的翻译方法。 
//
// 
//
// 示例 1: 
//
// 输入: 12258
//输出: 5
//解释: 12258有5种不同的翻译，分别是"bccfi", "bwfi", "bczi", "mcfi"和"mzi" 
//
// 
//
// 提示： 
//
// 
// 0 <= num < 2³¹ 
// 
//
// Related Topics 字符串 动态规划 👍 591 👎 0


package leetcode.editor.cn;

import java.util.Queue;

class 把数字翻译成字符串{
    public static void main(String[] args) {
        Solution solution = new 把数字翻译成字符串().new Solution();
        
    }

//leetcode submit region begin(Prohibit modification and deletion)
class Solution {
    public int translateNum(int num) {
        int pre = num % 10,cur, a = 1, b = 1;
        while (num != 0){
            num /= 10;
            cur = num % 10;
            int tmp = pre + cur * 10;
            int c = tmp >= 10 && tmp <= 25 ? a + b : b;
            a = b;
            b = c;
            pre = cur;
            
        }
        return b;
    }
}
//leetcode submit region end(Prohibit modification and deletion)

}
